Reprogramming the Omega Video Timing 



Definition of symbols: 



f n 


nonzonLai scan irecjutrncy, j\nz. 


Th 


horizontal scan, period, microseconds 


Fv 


vertical scan frequency. Hz. 


TV 


vertical scan period, milliseconds 


Oh 


horizontal blanking lime, microseconds 


Ih 


horizontal display time, microseconds 


Ov 


vertical blanking time, microseconds 


lv 


vertical display time, microseconds 


sh 


horizontal sync pulse duration, microseconds 


fh 


horizontal front porch, microseconds 


bh 


horizontal back porch, microseconds 


sv 


vertical sync pulse duration, microseconds 


fv 


vertical front porch, microseconds 


bv 


vertical back porch, microseconds 


X 


x resolution, pixels 


Y 


y resolution, pixels 


Zx 


x zoom factor 


Zy 


y zoom factor 


ct 


character time, microseconds (.4414 for Omega 400,. 3636 for iKxlK) 



The following timing diagrams illustrate how these symbols are used: 






These are relations between symbols derived from thein definitions: 



Fh=1000/Th 

Fv=1000/Tv 

Oh=fh+sh^bh 

Ov=fv-rsv-bv 

lb=Th-0h 

lv=Tv-Ov 

The Omega allows access to ten video timing control registers. These 
are loaded via the op code CRTWR (hex 46), followed by register number 
(range to 9) and the value to be written. In the following table, 
(r'O) means the contents of rO and thus is the value following '.the hex- 
sequence 46 00; similarly to write hex 57 into register 4, one 1 would 
transmit 46 04 57. 

(r0)=int Th/ct]-l .rO controls horizontal rate. 

(rl)=int[ih/ct]-2 ;ri controls horizontal display lime. Also 
;rl determines X resolution by. 

X'Zx=16\(rl)-2] 

(r2) = (rl)-int^hf /ct] ;r2 controls horizontal front porch. 

(r3)=16*inf sv/Th]-int[sh/ct] ,r3 controls horizontal AND vertical 
sync. 

(r4),r(5) and (r9) work together to define the 'vertical .period. One may 
choose any values that produce the correct period, within the con- 

(r4) ranges from to 127 decimal (r5) ranges from to 31 decimal (r9) 
ranges from to 31 decimal 

There are three formulas to use: 

interlace, (r4)*(r9) even: 2»int[Tv/Th]=[;(r4) + l]''[(r9)- i -2]+2*(r5)- 1 
interlace, (r4)'(r9) odd: 2*mt[Tv/Th] = [(r4) + lK(r9^ + 2]-h2*(r5) 
non-interlaced: iriti Tv/Th] = [(r4) + l]* l r (r9:)^l]+(r5') 

(r6): (r9) also : works with (r6) to define y resolution, and:may afTect the 
selection of (r9) in the previous calculations: 

interlaced: Zy*Y=(r6)*[(r9) + 2] 

non-interlaced: Zy*Y=(r6)*[(r9)+l] 

(note, no zoom means Zy=l; a times 2 zoom means Zy=l, etc). 



Selection of a value for r7 requires first that vertical front porch be 
rounded to the nearest, multiple of 4*Th for interlace and 8Th for non- 
interlace- these are the finest increments that the vertical sync pulse 
can be positioned. Assuming this has been done: 



(r7) = (r6)-int[vf/ct] 

(r8)=0'for non-interlaced 
=3 for interlaced 



APPLICATIONS 

Normally, one reprograms the Omega to optimize system performance. 
This could mean maximize X and Y resolution, and push monitor 
bandwidth to the limits of its performance. The Omega constraints are 
defined by: X and Y cannot exceed 1023 without wrap-around 

and ct is fixed by the crystal frequency 



The monitor typically is constrained in terms of most of the video timing 
parameters previously used One usually will try to achieve the maximum 
refresh rate to minimize flicker. 

Where some items are not included in the monitor spec, standards such 
as E1A RS-343 or RS-170 may be consulted. 

Both groups of constraints come into play in the first example, the stan- 
dard 1024 'by 768 resolution, 33 Hz interlace display of the standard 
Omega 400. 

Example 1: 1024 by 768. 34 Hz. interlaced. 



Assume we begin with X resolution: 
X=:024 = l6*((rl)-2] so (rl) = 66. 

Monitor blanking time is spec'ed at 6 microseconds, nominal RS-343 
specifies 7 25 useconds, max. It is'desirable to maximize blanking, as it 
allows the processor to operate aba higher duty cycle; so we choose the 
largest multiple of ct within 7 25 i e. 16. 



lh=cK(rl)-2]= 88.25 us. 

Th=28. 25-7. 06=34 31 usee. Fh=28.32 KHz (Within monitor specs) 
(r0) = (rl)-int[0h/ct]-3 ; since we chose Oh to be 16*ct, (r0) = 79 
Horizontal sync data are not in the 3619 spec, so we use RS-343. 
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Let sh=ct*int[2.75/ct] =2.65 usee. Let fh=ct*int[.75/ct] = .88 usee. 

fh determines (r2): (r2) = (rl)-int7h/ct] = (66)-2=68. 

The resulting backporch is generous; bp = 0h-fh-sh=3.53 usee. 

To continue, we use Y=768 (derived from aspect ratio considerations) 
and the RS-343 vertical retrace time of 1.25 msec. Actually, we use 1.257 
msec, as it is the closest multiple of Th/2. 

Tv=(7.68/2)*Th+l. 257=14. 48 msec. Fv=1000/Th=69.1 Hz field rate. The 
frame rate is half this, or 34.5 Hz. 

Now we can select total lines per frame: 

Lines=int[2»Tv/Th]=841. 

Since this number is odd, we use: 

B41 = [(r4) + :]*[(r9)-2]-2»(r5) and 768=;r6)*[(r9)-2]. Choose (r9) = 6 for 
convenience. Then 

(r6) = 96 (r4) = !03 (r5)=4 

Since we are interlaced, (r8)=3. All that remains is to select a. value for 
r7. The monitor spec says nothing about vertical sync position; RS-343 
says to 250 usee. We will minimize it to give the monitor the maximum 
time to stabilize before beginning the next scan. 

(r7) = (r6);' vf=0. Actually, due to hardware, a 2 usee vf exists. 

Example 2: 640 X 480 30 Hz. Interlaced (RS-170). 

R3-170 dictates almost all video parameters: 

Fh= 15.73426 KHz 
Th=63.555 usee 

FY=59.94 Hz 
Tv= 16.683 msec 

Other parameters are derived from these- 

0h=.i6*Th=10.168 usee 
ih=Th-0h=53.387 usee 
fh= 02*Th=1.27 usee 
sh=.08'Th=5 084 usee 
bh=.06 ,, Th=3 813 usee 

0v= 075*Tv=l 251 msec 
lv=Tv-0v= 15.432 msec 
fv=0 

sv=.04*Tv=667 msec 
bv=0v-sv = .5B4 msec 

The crystaj frequency required is 72.5035 MHz; this is the standard 
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Omega 400 crystal value. ]L yields a character time of: 

ct = 32/crystal freq. = .4414 usee 

Th dictates the value programmed into rO: 



Th/ct]-l=int[63.555/. 4414]-! = 143 

lh/ct]+2=123; however this would yield an Zx'X of 



(rO)=int 
(ri)=int 

16*121 = 1936. Assuming a Zx of 3, 645.3 pixels in x results So 

we must compromise the RS-170 standard, and let rl be set by resolution 

of 640 X: 

(ri)=int Zx'X/l6]+2=int 3*640/ 16]-2= 122 

(r2) = (rl)+int(fh/ct) = 122-^3= 125 

(r3) = l6*int(sv/Th)-int(sh/ct) = l6*3-il=59 

(r4),(r5) and (r9) are chosen for 525 scans per frame. Use the formula for 
interlaced, with (r4)"(r9) odd: 

525 = ^4)-! ]*>9)-2]^2*(r5)-l 

The problem is one of factoring 524 within the range constraints" on the 
registers. One combination that w^orks is: 

(r4) = 86 
(r5) = i 
(r9) = 4 

For (r6), use the target y resolution of 480: 
4B0 = (r6)\(r9) + 2] ; since (r9)=4. (r6) = 80 

(r7) is set by vf; assume this is zero, as the controller is restricted 
to multiples of 4*Th: 

(r7) = (r6)-int(vf/ct) = (r6)+B0 

and for this application. (rB)=3. 
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